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What is CloudSim Plus? 


Java 17+ independent CloudSim fork for Cloud 
Computing simulation 


https://cloudsimplus.org 


State-of-the-art cloud computing simulation 
framework for creationg of experiments to simulate 
cloud infrastructure and services, including: 


e development of algorithms for VM placement 
and migration; 

e VMs and applications scheduling; 

e computing resources allocation; 

e modelling of applications/tasks resource 
utilization; 

e power consumption models, power-efficient 
resource allocation; 

e network traffic modelling and more... 
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CloudSim Plus Introduction 


Highly extensible, completely redesigned and 
refactored. 

Full-featured: more than 20 exclusive 
features, and counting... 

DRY and Clean Code. 

Reduces duplication and redundancy. Way easier 
to use (comparison). 

Less 30% code duplication, more 80% test 
coverage. 

Integration tests to ensure accuracy of entire 
simulation scenarios. 
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CloudSim Plus Introduction 


e Fully documented: totally reviewed and 
extended docs. 

e Lots of meaningful examples to get you 
started. 

e + 20 contributors and counting... 

e Used to build lots of recent and relevant 
tools. 

e Actively maintained since 2016. 

e Download available from Maven Central. 
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Architecture 


e Simplified module structure, new modules 
introduced. 

e Totally re-organized, extended and documented 
packages. 

e New interfaces: increased abstraction, contracts 
for implementations. 
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Modules 


E CloudSim Plus API 
= 

| | CloudSim Plus 

= Examples 


e API: independent and only one required for 
building simulations. 

e Examples: exclusive examples, refactored 
previous ones. 

e Testbeds: multi-run simulations 
forscientifically valid data collection. 

e Benchmarks: performance assessment of 
features such as heuristics. 
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Main Packages 


datacenters 


allocationpolicies 


topologies 


selectionpolicies 
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Main Exclusive Features 


1. Joint power- and network-aware simulations”; 
. Vertical and Horizontal VM Scaling; 
. Host power on and off according to demand*; 
. Parallel execution of simulations; 
. Delayed and dynamic creation of VMs/Cloudlets; 
. Event Listeners for monitoring and data 
collection; 
7. Strongly Object-oriented Framework; 
8. Interfaces and Classes for implementation of 
Heuristics; 
9. Host Fault Injection Mechanism". 
10. Addition of Hosts at Simulation Runtime’; 
11. Linux Completely Fair Scheduler (CFS) and more 


No BW N 
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Vertical VM Scaling 


e resize of VM resources to fit workload 
e RAM, CPU, Bandwidth and Storage 
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Horizontal VM Scaling 


e creation of VMs for load balancing; 
e destruction of idle VMs for resource 
optimization. 
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Parallel Execution of Simulations 


PSA (m= NA 
559 
e Reduce processing time for large scale 


simulations 
e Relies on Java 8+ Parallel Streams 


mechanism: 


stmulations.parallelStream().forEach(MySimulatior. 
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Delay creation of submitted VMs and 
Cloudlets 


e Creation of objects at a given time, before 
starting the simulation 

e Used when the arrival times of objects are known 
in advance 
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Dynamic Creation of VMs and Cloudlets 
(Apps) 


e Enables creating objects after the simulation has 
started 

e Objects inter-arrival time can be simulated with 
some PRNG 
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Event Listeners 


e collect resource utilization data: 
= assess fulfillment of customer SLA 
= optimize resource allocation to avoid 
under/overload 
s granular simulation execution feedback 
e Listeners for events from Hosts, VMs, Cloudlets 
and more. 
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6. Strongly Object-oriented Framework 


e Actual relationships between objects: no ID-based 
relations 

e Fluent API, direct chained calls: 
cloudlet.getVm().getHost().getDatacenter( 

e Uses Null Object Pattern to avoid 
NullPointerException. 
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7. Interfaces/Classes for Heuristics 


e Contract to implement heuristics in some steps: 
1. initial solution generation; 
2. generation of neighbor solutions; 
3. definition of an utility function to be 
minimized or maximized; 
4. and then the solution finding stop criteria. 
e Examples: Tabu Search, Simulated 
Annealing, Ant Colony Systems; 
e Includes a Simulated Annealing heuristic for 
Cloudlet to VM mapping. 
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8. Linux Completely Fair Scheduler 
(CFS) 


CloudletScheduler: how a Vm schedules the 
execution of Cloudlets 

Bad scheduling: starvation, wastage of CPU 
cycles, SLA violations 

Completely Fair Scheduler reduces these 
issues (needs improvements [Lozi et. al. 
2016]) 

Considers tasks priorities to define CPU time 
slices 

CloudletSchedulerTimeShared: simplistic; 
preemption 
CloudletSchedulerCompletelyFair: more 
realistic implementation 
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Conclusions and Future Work 


e It is difficult to replicate a real system in 
simulation, mainly concerned in modelling the 
arrival of stochastic events such as workload 
bursts. 

e To contribute for valid results, a simulation 
framework has to: 

= be well-designed and extensively tested; 

= get away from code duplication to avoid code 
degeneration; 

s and provide classes following software 
engineering principles. 

e CloudSim Plus is aligned with all these 
requirements. 

e Proposed future work is available at the issues 


pase. 
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